import React, { useEffect, useState } from 'react';

export default function App() {
  // 准备组件的显示与隐藏
  const [isShow, setIsShow] = useState(true);
  return (
    <div>
      {isShow && <Child />}
      <button onClick={() => setIsShow(!isShow)}>点击卸载子组件</button>
    </div>
  );
}

function Child() {
  const fn = () => {
    console.log('窗口改变了  ----->  ');
  };
  // 在子组件中挂载时监听窗口改变事件
  useEffect(() => {
    window.addEventListener('resize', fn);

    // 语法： 返回一个函数
    return () => {
      // 💥💥函数，会在组件卸载时自动执行
      window.removeEventListener('resize', fn);
    };
  }, []);

  useEffect(() => {}, []);

  // 卸载时， 清除掉监听的窗口改变事件

  return <div>我是子组件</div>;
}
